###############################################################################
#
# Tests for XlsxWriter.
#
# SPDX-License-Identifier: BSD-2-Clause
#
# Copyright (c), 2013-2025, John McNamara, jmcnamara@cpan.org
#

from xlsxwriter.workbook import Workbook

from ..excel_comparison_test import ExcelComparisonTest


class TestCompareXLSXFiles(ExcelComparisonTest):
    """
    Test file created by XlsxWriter against a file created by Excel.

    """

    def setUp(self):
        self.set_filename("default_format07.xlsx")

    def test_create_file(self):
        """Test the creation of a file with user defined default format"""

        workbook = Workbook(
            self.got_filename,
            {
                "default_format_properties": {"font_name": "Calibri", "font_size": 11},
                "default_row_height": 20,
                "default_column_width": 64,
            },
        )

        worksheet = workbook.add_worksheet()

        worksheet.insert_image("E9", self.image_dir + "red.png", {"x_offset": 32})

        # Set user column width and row height to test positioning calculation.
        worksheet.set_column_pixels(4, 4, 96)
        worksheet.set_row_pixels(8, 32)

        # Set column to text column width less than 1 character.
        worksheet.set_column_pixels(6, 6, 10)

        workbook.close()

        self.assertExcelEqual()

    def test_create_file_with_character_units(self):
        """Test the creation of a file with user defined default format"""

        # Same as
        workbook = Workbook(
            self.got_filename,
            {
                "default_format_properties": {"font_name": "Calibri", "font_size": 11},
                "default_row_height": 20,
                "default_column_width": 64,
            },
        )

        worksheet = workbook.add_worksheet()

        worksheet.insert_image("E9", self.image_dir + "red.png", {"x_offset": 32})

        # Set user column width and row height to test positioning calculation.
        worksheet.set_column(4, 4, 13.0)
        worksheet.set_row(8, 24.0)

        # Set column to text column width less than 1 character.
        worksheet.set_column(6, 6, 0.83)

        workbook.close()

        self.assertExcelEqual()
